<template>
    <j-modal
        title="批量编辑"
        :visible="true"
        width="700px"
        @cancel="handleCancel"
        :destroyOnClose="true"
    >
        <div class="sizeText">
            将批量修改
            {{ data.length }} 条数据的【{{ labelName.join(',') }}】
        </div>
        <j-form
            class="form"
            layout="vertical"
            :model="formData"
            name="basic"
            autocomplete="off"
            ref="formRef"
        >
            <j-form-item label="值类型" v-if="provider === 'BACNetIp'">
                <j-select
                    v-model:value="formData.valueType"
                    allowClear
                    placeholder="请选择值类型"
                >
                    <j-select-option v-for="item in bacnetValueType" :key="item" :value="item">{{ item }}</j-select-option>
                </j-select>
            </j-form-item>
            <j-form-item label="访问类型" name="accessModes">
                <j-card-select
                    multiple
                    :showImage="false"
                    v-model:value="formData.accessModes"
                    :options="[
                        { label: '读', value: 'read' },
                        { label: '写', value: 'write' },
                        { label: '订阅', value: 'subscribe' },
                    ]"
                />
            </j-form-item>
            <j-form-item
                :name="['interval']"
                :rules="[
                    {
                        pattern: regOnlyNumber,
                        message: '请输入0或者正整数',
                    },
                ]"
            >
                <template #label>
                    <span>
                        采集频率
                        <j-tooltip title="采集频率为0时不执行轮询任务">
                            <AIcon
                                type="QuestionCircleOutlined"
                                style="margin-left: 2px"
                            />
                        </j-tooltip>
                    </span>
                </template>
                <j-input-number
                    style="width: 100%"
                    placeholder="请输入采集频率"
                    v-model:value="formData.interval"
                    addon-after="ms"
                    :max="2147483648"
                    :min="0"
                    :precision="0"
                />
            </j-form-item>

            <j-form-item :name="['features']">
                <j-checkbox-group v-model:value="formData.features">
                    <j-checkbox value="changedOnly" name="type"
                        >只推送变化的数据</j-checkbox
                    >
                </j-checkbox-group>
            </j-form-item>
        </j-form>
        <template #footer>
            <j-button key="back" @click="handleCancel">取消</j-button>
            <PermissionButton
                key="submit"
                type="primary"
                :loading="loading"
                @click="handleOk"
                style="margin-left: 8px"
                :hasPermission="`DataCollect/Collector:update`"
            >
                确认
            </PermissionButton>
        </template>
    </j-modal>
</template>
<script lang="ts" setup>
import type { FormInstance } from 'ant-design-vue';
import { savePointBatch, getBacnetValueType } from '@/api/data-collect/collector';
import { cloneDeep, isObject } from 'lodash-es';
import { regOnlyNumber } from '../../../data';

const props = defineProps({
    data: {
        type: Array,
        default: () => [],
    },
    provider: {
        type: String,
        default: '',
    }
});

const emit = defineEmits(['change']);
const loading = ref(false);
const formRef = ref<FormInstance>();

const formData = ref({
    accessModes: [],
    interval: undefined,
    features: [],
    valueType: undefined
});

const bacnetValueType = ref<string[]>([])

const getIdAndType = async () => {
  const resp: any = await getBacnetValueType()
  if(resp.success) {
    bacnetValueType.value = resp.result
  }
}



const handleOk = async () => {
    const data = cloneDeep(formData.value);
    const { accessModes, features, interval, valueType } = data;
    const ischange =
        accessModes.length !== 0 ||
        features.length !== 0 ||
        Number(interval) === 0 ||
        !!interval || !!valueType;
    if (ischange) {
        const params = cloneDeep(props.data);
        params.forEach((i: any) => {
            if (accessModes.length !== 0) {
                i.accessModes = data.accessModes;
            } else {
                if (isObject(i.accessModes)) {
                    i.accessModes = i.accessModes.map(
                        (item: any) => item.value,
                    );
                }
            }
            if(features.length !== 0) {
                i.features = data.features
            } else {
                i.features = i.features.map((it: any) =>it.value)
            }
            if (!!interval || Number(interval) === 0) {
                i.interval = data.interval;
                i.configuration = {
                    ...i.configuration,
                    interval: data.interval,
                };
            }
            if(data.valueType) {
                i.configuration = {
                    ...i.configuration,
                    valueType: data.valueType
                }
            }
        });
        loading.value = true;
        const response = await savePointBatch(params).catch(() => {});
        emit('change', response?.status === 200);
        loading.value = false;
    } else {
        emit('change', true);
    }
};

const handleCancel = () => {
    emit('change', false);
};

watch(() => props.provider, () => {
    if(props.provider === 'BACNetIp') {
        getIdAndType()
    }
}, { immediate: true });

const labelName = computed(() => {
  const arr = [];
  if (formData.value.accessModes.length) {
    arr.push('访问类型');
  }
  if (!!formData.value.interval) {
    arr.push('采集频率');
  }
  if (formData.value.features.length) {
    arr.push('只推送变化的数据');
  }
  if (formData.value.type) {
    arr.push('数据类型');
  }
  if (formData.value.valueType) {
    arr.push('值类型');
  }
  return arr;
});
</script>

<style lang="less" scoped>
.sizeText {
    margin-bottom: 20px;
}
</style>
